//定制请求的实例

//导入axios  npm install axios
import axios from 'axios'
import { ElMessage } from 'element-plus'
import { useTokenStore } from '@/stores/token'
//定义一个变量,记录公共的前缀  ,  baseURL
//const baseURL = 'http://localhost:8080';
const baseURL = '/api'
const instance = axios.create({baseURL})

// 添加请求拦截器
instance.interceptors.request.use(
    (config)=>{
         // 添加token
         const tokenStore = useTokenStore()
         // 判断有无token
         if (tokenStore.token) {
            // 有token，请求头携带token
            config.headers.Authorization = tokenStore.token
         }
         return config
    },
    (err)=>{
        Promise.reject(err)
    }
)

import router from '@/router'
// 添加响应拦截器
instance.interceptors.response.use(
    result=>{
         //如果业务状态码为0，代表本次操作成功
         if (result.data.code == 0) {
            return result.data
        }
        //代码走到这里，代表业务状态码不是0，本次操作失败
        //alert(result.data.message || '服务异常')
        ElMessage.error(result.data.message || '服务异常')
        return Promise.reject(result.data)//异步的状态转化成失败的状态
    },
    err=>{
        if (err.response.status === 401) {
            ElMessage.error('请先登录')
            router.push('/login')
        } else {
            ElMessage.error('服务异常')
        }
        return Promise.reject(err)//异步的状态转化成失败的状态
    }
)

export default instance;